+2005-05-18 Anders Carlsson <andersca@imendio.com>
+
+ * gtk/gtktextview.c: (gtk_text_view_flush_scroll),
+ (gtk_text_view_update_adjustments), (gtk_text_view_value_changed):
+ * gtk/gtktextview.h:
+ If the horizontal adjustment changes because of a change in the
+ layout width, then do a complete redraw. This is because there
+ might be right-aligned or centered text that needs to be redrawn.
+
2005-05-18 Matthias Clasen <mclasen@redhat.com>
* gtk/gtkwidget.c (gtk_widget_add_events): Try harder to set
+2005-05-18 Anders Carlsson <andersca@imendio.com>
+
+ * gtk/gtktextview.c: (gtk_text_view_flush_scroll),
+ (gtk_text_view_update_adjustments), (gtk_text_view_value_changed):
+ * gtk/gtktextview.h:
+ If the horizontal adjustment changes because of a change in the
+ layout width, then do a complete redraw. This is because there
+ might be right-aligned or centered text that needs to be redrawn.
+
2005-05-18 Matthias Clasen <mclasen@redhat.com>
* gtk/gtkwidget.c (gtk_widget_add_events): Try harder to set
+2005-05-18 Anders Carlsson <andersca@imendio.com>
+
+ * gtk/gtktextview.c: (gtk_text_view_flush_scroll),
+ (gtk_text_view_update_adjustments), (gtk_text_view_value_changed):
+ * gtk/gtktextview.h:
+ If the horizontal adjustment changes because of a change in the
+ layout width, then do a complete redraw. This is because there
+ might be right-aligned or centered text that needs to be redrawn.
+
2005-05-18 Matthias Clasen <mclasen@redhat.com>
* gtk/gtkwidget.c (gtk_widget_add_events): Try harder to set
scroll->use_align,
scroll->xalign,
scroll->yalign);
-
+
free_pending_scroll (scroll);
return retval;
if (text_view->width != width || text_view->height != height)
{
+ if (text_view->width != width)
+ text_view->width_changed = TRUE;
+
text_view->width = width;
text_view->height = height;
{
dx = text_view->xoffset - (gint)adj->value;
text_view->xoffset = adj->value;
+
+ /* If the change is due to a size change we need
+ * to invalidate the entire text window because there might be
+ * right-aligned or centered text
+ */
+ if (text_view->width_changed)
+ {
+ gdk_window_invalidate_rect (text_view->text_window->bin_window, NULL, FALSE);
+
+ text_view->width_changed = FALSE;
+ }
}
else if (adj == text_view->vadjustment)
{
guint accepts_tab : 1;
- /* this flag is no longer used */
- guint reserved : 1;
+ guint width_changed : 1;
/* debug flag - means that we've validated onscreen since the
* last "invalidate" signal from the layout
guint onscreen_validated : 1;
guint mouse_cursor_obscured : 1;
-
+
GtkTextWindow *text_window;
GtkTextWindow *left_window;
GtkTextWindow *right_window;